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LISTING OF CLAIMS 

This listing of claims replaces all prior versions and listings of claims in the 
application: 

1 . (currently amended): A method for distributing read 
commands to disks associated with a redundant array of inexpensive disks 
(RAID) mirroring system, comprising: 

estabUshing a first and second coxmter, the first counter associated with 
a first disk drive, the second counter associated with a second disk drive; 

receiving a command fi"om an operating system; 

determining if the received command is a read command; 

examining the first and second counters if the received command is the 
read command, the examining including, 

determining which of the first and second counters is a lower value 
counter or if the first and second counters are of equal value; 

selecting a drive associated with the lower value counter or if the 
counters are of equal value selecting a first drive; 

incrementing the lower value coimter or the first counter if counters are 
of equal value; and 

directing the read command to the drive associated with the lower 
value counter or the first drive if the coimters are of equal value. 

2. (original): The method as recited in claim 1, further including: 
providing a multithread environment for receiving multiple commands 

firom the operating system. 

3. (original): The method as recited in claim 1, wherein directing the 
read command to the drive associated with the lower value counter, includes: 

sending the read command to a drive queue of the drive associated 
with the lower value counter. 
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4. (original): The method as recited in claim 3, wherein the drive 
queue holds 256 conmiands. 

5. (previously amended): The method as recited in claim 1, 
wherein the RAID system is one of a software RAID implementation and a 
hardware RAID implementation. 

6. (previously amended): The method as recited in claim 1, 
wherein the method operation of determining if the received command is a 
read command includes, evaluating a command descriptor block associated 
with the command. 

7. (original): A method for maintaining a substantially even 
load of read commands on multiple disk drives associated with a RAID 
mirroring system, comprising: 

associating each of the multiple disk drives with a counter, each 
counter being configured to track a queue of read commands for a 
corresponding disk drive; 

examining each coimter to identify a least loaded disk drive; 

incrementing the counter associated with the least loaded disk drive; 

sending a read command to the least loaded disk drive; 

processing the read command in the least loaded disk drive; 

generating an interrupt; and 

decrementing the counter associated with the least loaded disk drive in 
response to the generated interrupt. 

8. (original): The method as recited in claim 7, fiirther 
including: 

providing a multithread environment, the multithread environment 
allowing multiple read commands to be processed concurrently. 

9. (original): The method as recited in claim 7, wherein the 
interrupt is a small computer system interface (SCSI) interrupt. 
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10. (original): The method as recited in claim 7, further 
including: 

reporting to an operating system that the read command has been 
processed. 

1 1 . (original): A computer readable media having program 
instmctions for maintaining a substantially even load of read commands on 
multiple disk drives associated with a RAID mirroring system, comprising: 

program instructions for associating each of the multiple disk drives 
with a counter, each counter being configured to track a queue of read 
commands for a corresponding disk drive; 

program instructions for examining each coimter to identify a least 
loaded disk drive; 

program instructions for incrementing the counter associated with the 
least loaded disk drive; 

program instructions for sending a read command to the least loaded 
disk drive; 

program instructions for processing the read command in the least 

loaded disk drive; 

program instructions for generating an interrupt; and 

program instructions for decrementing the counter associated with the 

least loaded disk drive in response to the generated interrupt. 

12. (original): The computer readable media as recited in claim 
11, wherein the interrupt is a small computer system interface (SCSI) 
interrupt. 

13. (original): The computer readable media as recited in claim 
11, wherein the RAID system is one of a software RAID implementation and a 
hardware RAID implementation. 
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14. (original): The computer readable media as recited in claim 
1 1, further including: 

program instructions for providing a multithread environment, the 
multithread environment allowing multiple read commands to be processed 
concurrently. 

1 5. (currently amended): An apparatus for distributing read 
commands between disk drives, the apparatus comprising: 

a central processing unit; 

an operating system, the operating system configured to generate 
commands; 

a first and second disk drive, the first disk drive being associated with a 
first counter, the second disk drive being associated with a second counter, 
wherein the first and second disk drives are mirrors of one another; and 

a RAID driver in communication with the first and second disk drives, 
the RAID driver including code for identifying a read command from the 
generated commands and identifying a least busy disk drive, wherein the read 
command is sent to the least busy disk drive. 

16. (previously amended): The apparatus as recited in claim 
15, wherein the RAID driver is configured to evaluate a command descriptor 
block. 

17. (original): The apparatus as recited in claim 15, further 
including: 

a first and second queue, the first queue corresponding to the first disk 
drive the second queue corresponding to the second disk drive, the first and 
second queue configured to hold multiple commands. 
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18. (original): The apparatus as recited in claim 15, further 
including: 

a multithread environment, the multithread environment configured to 
process multiple read commands concurrently. 

19. (original): The apparatus as recited in claim 15, wherein 
the RAID driver is a RAID controller, 

20. (original): The apparatus as recited in claim 17, wherein the first 
and second queue each have a 256 command capacity. 

21 . (new): An apparatus for maintaining a substantially 
even load of read commands on multiple disk drives associated with a RAID 
mirroring system, comprising: 

a central processing unit; 

an operating system, the operating system configured to generate 
commands; 

a first and second disk drive, wherein each of the first and second disk 
drives is associated with a counter, each coimter being configured to track a 
queue of read commands; and 

a RAID driver in communication with the first and second disk drives, 
the RAID driver including code for identifying a read command fi-om the 
generated commands and identifying a least busy disk drive, wherein the read 
command is sent to the least busy disk drive to increment the counter of the 
least busy disk drive and the completion of the read command decrements the 
counter associated with the least busy disk drive in response to a generated 
interrupt. 

22. (new): The apparatus of claim 21, wherein the 
generated interrupt is a small computer system interface (SCSI) interrupt. 
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